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Data-processing system 



FIELD OF THE INVENTION 

The invention relates to a data-processing system comprising a microprocessor 
and a communication device communicating with an electronic module intended to send a 
convention signal to the microprocessor. The invention may be used in the systems using an 
electronic module, such as mobile phones, or bank applications. In this case, the electronic 
module is generally constituted by a card of the SIM type (SIM is the abbreviation of 
Subscriber Identity Module). 

DESCRIPTION OF THE PRIOR ART 

An electronic module generally takes the form of a microprocessor smart card 
which is inserted into a terminal or is present in this terminal. In a system using such an 
electronic module, a communication device allows communication of data between the 
electronic module and the microprocessor of the system. 

The typical structure of a communication device, such as is used in the printed 
circuit PCF5087x, in which the electronic module is a SIM card, comprises a software unit 
and a register device. In this device, the time for performing an operation plays an important 
role as far as the real-time constraint is concerned. The software operation associated with the 
communication device is critical for this real-time constraint because it increases the time for 
processing certain operations. 

SUMMARY OF THE INVENTION 

It is an object of the invention to allow a reduction of time for processing 

operations. 

According to the invention a data-processing system as defined in the opening 
paragraph also comprises a hardware circV^llowing inversion or no inversion of the order 
of bits of a word as a function of the value Mthe convention signal during transfer of this 
word between the electronic module and the nSycroprocessor. 

The invention takes the following aspects into consideration. During 
communication of data between the electronic module and the microprocessor, there are two 
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conventions, direct and indirect, the convention used being dependent on the type of 
electronic module. These two conventions exist for historical reasons and are specified in the 
standard IS07816-3. When the direct convention is used, the order of bits of a word sent by 
the electronic module must remain unchanged in order that this word can be processed by the 
5 microprocessor. When the indirect convention is used, the order of bits of a word sent by the 
electronic module must be inverted so that this word can be processed by the microprocessor. 
This operation necessitates a processing operation by a processing device which must be 
present in all the systems using an electronic module, because, on the one hand, the type of 
electronic module which is present or is inserted into the system is not known a priori and, on 
1 0 the other hand, several electronic devices of different types may be present in or inserted into 
the same system. 

According to the prior art, the processing device allowing inversion or no 

M= inversion of the order of bits of a word as a function of the convention during transfer of this 

□ 

O word between the electronic module and the microprocessor has the following characteristic 
Hi 15 features. The words exchanged between the electronic module and the microprocessor are 8- 
M3 bit words. When the electronic module sends the data to the microprocessor, the first word 
m sent is a word TS of 8 bits which indicates if either the direct or the indirect convention is 

used. A software unit situated between the electronic module and the microprocessor detects, 
M= thanks to TS, the convention used. This software unit comprises a table of 256 words of 8 
5 20 bits which comprises, for each 8-bit word, its equivalent in the indirect convention, i.e. with 
p the order of bits inverted. When the detected convention is the direct convention, the software 
unit transmits the word received from the electronic module to the microprocessor without 
changing this word. When the indirect convention is detected, the software unit transmits the 
equivalent in the indirect convention of the word received from the electronic module to the 
25 microprocessor. The words transmitted to the microprocessor are processed by the register 
device within the communication unit of the microprocessor. When the data are transferred 
from the microprocessor to the electronic module, the principle is the same as that described 
above. This processing device requires a software unit which increases the duration of the 
processing operation during communication of data between the electronic module and the 
30 microprocessor, which is critical for the real-time constraint. 

The following principle allows a reduction of the processing time caused by 
the existence of two conventions during the transfer of words between the electronic module 
and the microprocessor. This processing operation is realized by a hardware circuit (as 
opposed to "software" when the processing operation is performed by a software unit). When 




, ,PH^000130 

3 18.10.2001 
the words are transferred from the electronic module to the microprocessor, the 8-bit words 
transmitted by the electronic module are loaded into a transfer register device which 
comprises two shift registers, one on the left and the other on the right. This transfer register 
device is situated in the communication device. A word B (Bytes) of 8 bits loaded into the 
5 transfer register device is loaded into the right shift register so as to give a word RB and into 
the left register so as to give a word LB. The word RB is strictly identical to the word B 
while the order of bits of the word LB is inverted with respect to the order of bits of the word 
B. A convention bit C is derived from the word TS transmitted by the electronic module 
during the transfer of data between this electronic module and the microprocessor. This 
10 convention bit C controls a selection circuit which is situated between the right shift register 
and the left shift register. As a function of the nature of the convention, direct or indirect, this 
selection circuit allows loading of the word RB or the word LB into a latched register device 
Jz which is present in the communication unit of the microprocessor. When the data are 

Q transferred from the microprocessor to the electronic module, the 8-bit words contained in the 

IP_ 15 latched register device are loaded into the right shift register and into the left shift register of 
£ the transfer register device of the communication device. As a function of the convention, 

; : : 

tfl another selection circuit controlled by the convention bit C allows selection of either the 

word stored in the right shift register or the word stored in the left shift register, which word 
will be sent to the electronic module. A time gain with respect to the processing operation 
Q 20 performed by the software unit can be obtained by this hardware circuit, which time gain will 
rf be higher as the number of words exchanged per second between the electronic module and 

the microprocessor is higher. 

These and other aspects of the invention are apparent from and will be 
elucidated, by way of non-limitative example, with reference to the embodiment(s) described 
25 hereinafter. 



BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a diagram illustrating the characteristic features of the invention; 

Fig. 2 illustrates a signal used for detecting the convention, as well as for 
30 generating the convention bit; 

Fig. 3 is a block diagram illustrating the use of the invention in a system for 
transferring data between an electronic module and a random access memory; 

Fig. 4 illustrates an embodiment of a hardware circuit for transferring data 
from an electronic module to a microprocessor; 
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Fig. 5 illustrates an embodiment of a switch used in a hardware circuit for 

transferring data from an electronic module to a microprocessor; 

Fig. 6 illustrates an embodiment of a hardware circuit for transferring data 

from a microprocessor to an electronic module. 

5 

DESCRIPTION OF PREFERRED EMBODIMENTS 

Fig. 1 illustrates characteristic features of the invention, as described 
hereinbefore. A data-processing system comprises a communication device [COM] 
communicating with an electronic module [MOD], a hardware circuit [HARD] and a 
10 microprocessor [PRC]. 

The electronic module [MOD] is present in or inserted into a terminal and 
comprises information relating to the subscriber. For example, the electronic module [MOD] 

M allows control of the memory dedicated to the user, integration of security mechanisms or 

O 

q realization of payments from a distance. In order to process the information comprised in the 

Tl 15 electronic module [MOD], the terminal comprises the microprocessor [PRC] which 
J3 exchanges data with the electronic module [MOD] via the communication device [COM]. 

Jjs For the exchange of data, there are two conventions, a direct and an indirect convention. 

These two conventions can be taken into account by the circuit [HARD] during an exchange 
i* of data between the electronic module [MOD] and the microprocessor [PRC]. When a first 
20 data word [BYT1] is transmitted from the electronic module [MOD] to the microprocessor 
O [PRC], it is processed by the hardware circuit [HARD] which transmits a second data word 
[BYT2] to the microprocessor. In the case where the direct convention is used, the second 
data word [BYT2] is identical to the first data word [BYT1]. In the case where the indirect 
convention is used, the order of bits of the second data word [BYT2] is inverted with respect 
25 to the order of bits of the first data word [BYT1]. When a third data word [BYT3] is 

transmitted from the microprocessor [PRC] to the electronic module [MOD], it is processed 
by the hardware circuit [HARD] which transmits a fourth data word [B YT4] to the electronic 
module [MOD]. In the case where the direct convention is used, the fourth data word [BYT4] 
is identical to the third data word [BYT3]. In the case where the indirect convention is used, 
30 the order of bits of the fourth data word [BYT4] is inverted with respect to the order of bits of 
the third data word [BYT3]. 

Fig. 2 illustrates a direct convention signal [TSDC] and an indirect convention 
signal [TSIC] transmitted by an electronic module during communication of data with a 
microprocessor. Each of these signals is a word of 8 bits enumerated first to eighth [bl-b8]. 
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The bits [b4], [b5] and [b6] are coded for the convention. When the bits [b4], [b5] and [b6] 
have a value of 1, the direct convention is used. When the bits [b4], [b5] and [b6] have a 
value of 0, the indirect convention is used. 

Fig. 2 also illustrates how a convention bit [bC] is generated from the signal 
5 [TSDC] or from the signal [TSIC]. The bit [b6] is applied to the input of an inverter [INV]. 
The output of this inverter [INV] is the convention bit [bC]. This convention bit [bC] has the 
value of 0 when the direct convention is used and 1 when the indirect convention is used. 

Fig. 3 illustrates the use of the invention in a system for transferring data 
between an electronic module [MOD] and a random access memory. The data transfer 
10 system comprises a communication unit [COM] comprising a transfer register device [SIB], a 
latched register [LR] and a hardware circuit [HARD], a direct access memory [DMA] and a 
random access memory [RAM]. 

When the data are transferred from the electronic module [MOD] to the 
random access memory [RAM], a word of 8 bits is transmitted in series from the electronic 
module [MOD] to the transfer registeMevice [SIB], one of whose roles is to effect a series- 
parallel conversion. The hardware circuit [HARD] allows inversion or no inversion of the 
order of bits of the word at the output of this fca$sfer register device [SIB] as a function of 
the convention used. The operation of this ^^Sware circuit [HARD] will be described in 
greater detail with reference to Figs. 4, 5 ancf&. The word is sent in parallel to the latched 
920 register [LR] whose role is to receive the words\from the transfer register device [SIB] before 
Mi these are used by the random access memory [RAM]. The direct access memory [DMA] 

extracts the word stored in the locked register [LR] in order to send it to the random access 
memory [RAM]. When the data are transferred from fee random access memory [RAM] to 
the electronic module [MOD], the principle is the same\s described above. In this case, one 
25 of the roles of the transfer register device [SIB] is to reali^p a parallel-series conversion. 

Fig. 4 illustrates a hardware circuit for the transfer of data from an electronic 
module to a microprocessor. The hardware circuit comprises a right shift register module- 
microprocessor [RXMP], a left shift register module-microprocessor [RYMP], a latched 
register module-microprocessor [LRMP] and 8 module-microprocessor switches [SWHMP]. 
30 In the Figure, only one module-microprocessor switch [SWHMP] has been referenced for 
reasons of convenience. The 7 other module-microprocessor switches [SWHMP] are 
identical and represented by identical symbols. 

The first data word [BYT1] of 8 bits enumerated first to eighth (bl, b8) is 
transmitted in series by the electronic module to the transfer register device. It is then loaded 
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into the right shift register module-microprocessor [RXMP] as well as into the left shift 
register module-microprocessor [RYMP]. The right shift register module-microprocessor 
[RXMP] is intended to comprise words of 8 bits enumerated first to eighth [bxl, bx8]. The 
left shift register module-microprocessor [RYMP] is intended to comprise words of 8 bits 
enumerated first to eighth [byl, by8]. When the first data word [BYT1] is loaded into the 
right shift register module-microprocessor [RXMP], the bit [bxl] is equal to the bit bl, the bit 
[bx2] is equal to the bit b2, and so forth, until bit [bx8], which is equal to bit b8. When the 
first data word [BYT1] is loaded into the left shift register module-microprocessor [RYMP], 
the bit [byl] is equal to the bit b8, the bit [by2] is equal to the bit b7, and so forth until the bit 
[by8], which is equal to the bit bl, i.e. the order of bits is inverted. The module- 
microprocessor switch [SWHMP] number n (n being an integral number between 1 and 8) 
has the convention bit [bC] for control and the bits bxn and byn as inputs. In the case where 
the direct convention is used, i.e. in the case where the convention bit [bC] has a value of 0, 
the output bsn of the module-microprocessor switch [SWHMP] number n is the bit bxn. In 
the case where the indirect convention is used, i.e. in the case where the convention bit [bC] 
has a value of 1, the output bsn of the module-microprocessor switch [SWHMP] number n is 
the bit byn. The 8 bits enumerated first to eighth (bsl, bs8) constitute the second data word 
[BYT2]. Each bit bsn is loaded in parallel into the latched register module-microprocessor 
[LRMP] intended to comprise words of 8 bits enumerated first to eighth [bll, bl8]. The bit 
bll is then equal to the bit bsl, the bit bl2 is equal to the bit bs2 and so forth until the bit bl8, 
which is equal to the bit bs8. 



used in a hardware circuit for a transfer of data from an electronic module to a 
microprocessor. The module-microprocessor switch [SWHMP] comprises a first NAND gate 
[NAND1], a second NAND gate [NAND2], a third NAND gate [NAND3], a first inverter 
[INV1] and a second inverter [INV2]. 



[byn] passes through the first inverter [INV1]. The output of this first inverter [INV1] as well 
as the convention bit [bC] are applied to the inputs of the first NAND gate [NAND1]. The 
convention bit [bC] is applied to the input of the second inverter [INV2]. The output of this 
second inverter [INV2] as well as the bit [bxn] are applied to the inputs of the second NAND 
gate [NAND2]. The outputs of the first NAND gate [NAND1] and the second NAND gate 
[NAND2] are applied to the inputs of the third NAND gate [NAND3]. The output bit of this 
third NAND gate [NAND3] is the bit [bsn]. When the direct convention is used, the 



Fig. 5 illustrates an example of a module-microprocessor switch [SWHMP] 



This module-microprocessor switch [SWHMP] operates as follows. The bit 
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convention bit [bC] has a value of 0. The inverse logic value of bit [byn] as well as the 
convention bit [bC] which has a value of 0 are applied to the inputs of the first NAND gate 
[NAND1]. The output of the first NAND gate [NAND1] thus has a value of 1, irrespective of 
the value of the bit [byn]. The inverse logic value of the convention bit [bC], i.e. 1, as well as 
the bit [bxn] are applied to the inputs of the second NAND gate [NAND2]. The output of the 
second NAND gate [NAND2] is thus equal to the inverse logic value of the bit [bxn]. 
Consequently, the output of the third NAND gate [NAND3], i.e. the bit [bsn], is equal to the 
bit [bxn]. When the indirect convention is used, the convention bit [bC] has a value of 1 . The 
inverse logic value of the bit [byn] as well as the convention bit [bC] which has a value of 1 
are applied to the inputs of the first NAND gate [NAND1]. The output of the first NAND 
gate [NAND1] is thus equal to the bit [byn]. The inverse logic value of the convention bit 
[bC], i.e. 0, as well as the bit [bxn] are applied to the inputs of the second NAND gate 
[NAND2]. The output of the second NAND gate [NAND2] thus has a value of 1, irrespective 
of the value of the bit [bxn]. Consequently, the output of the third NAND gate [NAND3], i.e. 
the bit [bsn], is equal to the inverse logic value of the bit [byn]. 

The module-microprocessor switch [SWHMP] illustrated in this Figure allows 
inversion, at the same time, of the order and the value of the bits of a word when the indirect 
convention is used. Another switch allowing inversion of only the order of bits of a word 
may be derived from this module-microprocessor switch [SWHMP] by removing the first 
inverter [INV1]. 

Fig. 6 illustrates a hardware circuit for transfer of data from a microprocessor 
to an electronic module. The hardware circuit comprises a left shift register microprocessor- 
module [RXPM], a right shift register microprocessor-module [RYPM], a latched register 
microprocessor-module [LRPM] and a microprocessor-module switch [SWHPM]. 

The data word to be transmitted from the microprocessor to the electronic 
module is stored in the latched register microprocessor-module [LRPM]. This data word is 
the third data word [BYT3] of 8 bits enumerated first to eighth [Ml, bl8]. For transmission to 
the electronic module, this word is first loaded in parallel into the left shift register 
microprocessor-module [RXPM] as well as into the right shift register microprocessor- 
module [RYPM]. The left shift register microprocessor-module [RXPM] is intended to 
comprise words of 8 bits enumerated first to eighth [bxl, bx8]. The right shift register 
microprocessor-module [RYPM] is intended to comprise words of 8 bits enumerated first to 
eighth [byl, by8]. When the third data word [BYT3] is loaded into the left shift register 
microprocessor-module [RXPM], the bit [bxl] is equal to bit bl, the bit [bx2] is equal to bit 
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b2, and so forth until the bit [bx8] which is equal to bit b8. When the third data word [BYT3] 
is loaded into the right shift register microprocessor-module [RYPM], the bit [byl] is equal 
to bit bl, the bit [by2] is equal to bit b2 and so forth until the bit [by8], which is equal to bit 
b8. The microprocessor-module switch [SWHPM] has the convention bit [bC] for control 
5 and receives in series, at one of its inputs, the data word stored in the left shift register 

microprocessor-module [RXPM], which is identical to the third data word [BYT3], and, at 
the other input, the data word stored in the right shift register microprocessor-module 
[RYPM], of which the order of bits is inverted with respect to the order of bits of the third 
data word [BYT3]. This microprocessor-module switch [SWHPM] processes the bits of each 
10 of its words one after the other, i.e. it has the bit [bxl] and the bit [by8] as its inputs, then the 
bit [bx2] and the bit [by7], and so forth until the bit [bx8] and the bit [byl]. This 
microprocessor-module switch [SWHPM] is identical to the module microprocessor switch 
1^ [SWHMP] described with reference to Fig. 4. Let it be assumed that the microprocessor- 

module switch (SWHPM] has the bit bxn and the bit by(9-n) as its inputs, for example, b3 
H 1 5 and b6. In the case where the direct convention is used, i.e. in the case where the convention 
yg bit [bC] has a value of 0, the output of the microprocessor-module switch [SWHPM] is the 

!t bit bxn. In the case where the indirect convention is used, i.e. in the case where the 

y i 

s convention bit [bC] has a value of 1, the output of the microprocessor-module switch 

^ [SWHPM] is the inverse logic value of the bit by(9-n). The 8 consecutive output bits of the 

W 20 microprocessor module switch [SWHPM] constitute the fourth data word [BYT4]. The 
O remark made at the end of the description of Fig. 5 similarly applies in this case: it is possible 
to use another microprocessor-module switch in order to invert only the order of bits of a 
word when the indirect convention is used. 

The data-processing system shown in Figs. 3 to 6 is an example of using the 
25 characteristic features illustrated in Fig. 1 . 

The description above with reference to the Figures illustrates rather than 
limits the invention. It will be evident that there are numerous alternatives within the scope of 
the appended claims. In this respect, several remarks will be made in conclusion. 

There are numerous ways of inverting or not inverting the order of bits of a 
30 word as a function of the convention during transfer of data between the electronic module 
and the microprocessor. Figs. 3 to 6 only illustrate a possible embodiment in which 2 shift 
registers as well as a hardware circuit are used for realizing this function. It is possible to use 
other, possibly more complex circuits for realizing this function. 



